/* Copyright 2014 Mozilla Foundation
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

:root {
	--highlight-bg-color: rgba(180, 0, 170, 1);
	--highlight-selected-bg-color: rgba(0, 100, 0, 1);
}

@media screen and (forced-colors: active) {
	:root {
		--highlight-bg-color: Highlight;
		--highlight-selected-bg-color: ButtonText;
	}
}

.textLayer {
	position: absolute;
	text-align: initial;
	inset: 0;
	overflow: hidden;
	opacity: 0.25;
	line-height: 1;
	-webkit-text-size-adjust: none;
	-moz-text-size-adjust: none;
	text-size-adjust: none;
	forced-color-adjust: none;
	transform-origin: 0 0;
	z-index: 2;
}

.textLayer :is(span, br) {
	color: transparent;
	position: absolute;
	white-space: pre;
	cursor: text;
	transform-origin: 0% 0%;
}

/* Only necessary in Google Chrome, see issue 14205, and most unfortunately
 * the problem doesn't show up in "text" reference tests. */
.textLayer span.markedContent {
	top: 0;
	height: 0;
}

.textLayer .highlight {
	margin: -1px;
	padding: 1px;
	background-color: var(--highlight-bg-color);
	border-radius: 4px;
}

.textLayer .highlight.appended {
	position: initial;
}

.textLayer .highlight.begin {
	border-radius: 4px 0 0 4px;
}

.textLayer .highlight.end {
	border-radius: 0 4px 4px 0;
}

.textLayer .highlight.middle {
	border-radius: 0;
}

.textLayer .highlight.selected {
	background-color: var(--highlight-selected-bg-color);
}

.textLayer ::-moz-selection {
	background: blue;
	background: AccentColor;
	/* stylelint-disable-line declaration-block-no-duplicate-properties */
}

.textLayer ::selection {
	background: blue;
	background: AccentColor;
	/* stylelint-disable-line declaration-block-no-duplicate-properties */
}

/* Avoids https://github.com/mozilla/pdf.js/issues/13840 in Chrome */
.textLayer br::-moz-selection {
	background: transparent;
}

.textLayer br::selection {
	background: transparent;
}

.textLayer .endOfContent {
	display: block;
	position: absolute;
	inset: 100% 0 0;
	z-index: -1;
	cursor: default;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
}

.textLayer .endOfContent.active {
	top: 0;
}

:root {
	--annotation-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");
	--input-focus-border-color: Highlight;
	--input-focus-outline: 1px solid Canvas;
	--input-unfocused-border-color: transparent;
	--input-disabled-border-color: transparent;
	--input-hover-border-color: black;
	--link-outline: none;
}

@media screen and (forced-colors: active) {
	:root {
		--input-focus-border-color: CanvasText;
		--input-unfocused-border-color: ActiveText;
		--input-disabled-border-color: GrayText;
		--input-hover-border-color: Highlight;
		--link-outline: 1.5px solid LinkText;
		--hcm-highligh-filter: invert(100%);
	}

	.annotationLayer .textWidgetAnnotation :is(input, textarea):required,
	.annotationLayer .choiceWidgetAnnotation select:required,
	.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input:required {
		outline: 1.5px solid selectedItem;
	}

	.annotationLayer .linkAnnotation:hover {
		-webkit-backdrop-filter: var(--hcm-highligh-filter);
		backdrop-filter: var(--hcm-highligh-filter);
	}

	.annotationLayer .linkAnnotation > a:hover {
		opacity: 0 !important;
		background: none !important;
		box-shadow: none;
	}

	.annotationLayer .popupAnnotation .popup {
		outline: calc(1.5px * var(--scale-factor)) solid CanvasText !important;
		background-color: ButtonFace !important;
		color: ButtonText !important;
	}

	.annotationLayer .highlightArea:hover::after {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		-webkit-backdrop-filter: var(--hcm-highligh-filter);
		backdrop-filter: var(--hcm-highligh-filter);
		content: "";
		pointer-events: none;
	}

	.annotationLayer .popupAnnotation.focused .popup {
		outline: calc(3px * var(--scale-factor)) solid Highlight !important;
	}
}

.annotationLayer {
	position: absolute;
	top: 0;
	left: 0;
	pointer-events: none;
	transform-origin: 0 0;
	z-index: 3;
}

.annotationLayer[data-main-rotation="90"] .norotate {
	transform: rotate(270deg) translateX(-100%);
}

.annotationLayer[data-main-rotation="180"] .norotate {
	transform: rotate(180deg) translate(-100%, -100%);
}

.annotationLayer[data-main-rotation="270"] .norotate {
	transform: rotate(90deg) translateY(-100%);
}

.annotationLayer canvas {
	position: absolute;
	width: 100%;
	height: 100%;
	pointer-events: none;
}

.annotationLayer section {
	position: absolute;
	text-align: initial;
	pointer-events: auto;
	box-sizing: border-box;
	transform-origin: 0 0;
}

.annotationLayer .linkAnnotation {
	outline: var(--link-outline);
}

.annotationLayer :is(.linkAnnotation, .buttonWidgetAnnotation.pushButton) > a {
	position: absolute;
	font-size: 1em;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.annotationLayer :is(.linkAnnotation, .buttonWidgetAnnotation.pushButton):not(.hasBorder) > a:hover {
	opacity: 0.2;
	background-color: rgba(255, 255, 0, 1);
	box-shadow: 0 2px 10px rgba(255, 255, 0, 1);
}

.annotationLayer .linkAnnotation.hasBorder:hover {
	background-color: rgba(255, 255, 0, 0.2);
}

.annotationLayer .hasBorder {
	background-size: 100% 100%;
}

.annotationLayer .textAnnotation img {
	position: absolute;
	cursor: pointer;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea),
.annotationLayer .choiceWidgetAnnotation select,
.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input {
	background-image: var(--annotation-unfocused-field-background);
	border: 2px solid var(--input-unfocused-border-color);
	box-sizing: border-box;
	font: calc(9px * var(--scale-factor)) sans-serif;
	height: 100%;
	margin: 0;
	vertical-align: top;
	width: 100%;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea):required,
.annotationLayer .choiceWidgetAnnotation select:required,
.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input:required {
	outline: 1.5px solid red;
}

.annotationLayer .choiceWidgetAnnotation select option {
	padding: 0;
}

.annotationLayer .buttonWidgetAnnotation.radioButton input {
	border-radius: 50%;
}

.annotationLayer .textWidgetAnnotation textarea {
	resize: none;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea)[disabled],
.annotationLayer .choiceWidgetAnnotation select[disabled],
.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input[disabled] {
	background: none;
	border: 2px solid var(--input-disabled-border-color);
	cursor: not-allowed;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea):hover,
.annotationLayer .choiceWidgetAnnotation select:hover,
.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input:hover {
	border: 2px solid var(--input-hover-border-color);
}

.annotationLayer .textWidgetAnnotation :is(input, textarea):hover,
.annotationLayer .choiceWidgetAnnotation select:hover,
.annotationLayer .buttonWidgetAnnotation.checkBox input:hover {
	border-radius: 2px;
}

.annotationLayer .textWidgetAnnotation :is(input, textarea):focus,
.annotationLayer .choiceWidgetAnnotation select:focus {
	background: none;
	border: 2px solid var(--input-focus-border-color);
	border-radius: 2px;
	outline: var(--input-focus-outline);
}

.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) :focus {
	background-image: none;
	background-color: transparent;
}

.annotationLayer .buttonWidgetAnnotation.checkBox :focus {
	border: 2px solid var(--input-focus-border-color);
	border-radius: 2px;
	outline: var(--input-focus-outline);
}

.annotationLayer .buttonWidgetAnnotation.radioButton :focus {
	border: 2px solid var(--input-focus-border-color);
	outline: var(--input-focus-outline);
}

.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::before,
.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::after,
.annotationLayer .buttonWidgetAnnotation.radioButton input:checked::before {
	background-color: CanvasText;
	content: "";
	display: block;
	position: absolute;
}

.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::before,
.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::after {
	height: 80%;
	left: 45%;
	width: 1px;
}

.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::before {
	transform: rotate(45deg);
}

.annotationLayer .buttonWidgetAnnotation.checkBox input:checked::after {
	transform: rotate(-45deg);
}

.annotationLayer .buttonWidgetAnnotation.radioButton input:checked::before {
	border-radius: 50%;
	height: 50%;
	left: 30%;
	top: 20%;
	width: 50%;
}

.annotationLayer .textWidgetAnnotation input.comb {
	font-family: monospace;
	padding-left: 2px;
	padding-right: 0;
}

.annotationLayer .textWidgetAnnotation input.comb:focus {
	/*
   * Letter spacing is placed on the right side of each character. Hence, the
   * letter spacing of the last character may be placed outside the visible
   * area, causing horizontal scrolling. We avoid this by extending the width
   * when the element has focus and revert this when it loses focus.
   */
	width: 103%;
}

.annotationLayer .buttonWidgetAnnotation:is(.checkBox, .radioButton) input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

.annotationLayer .fileAttachmentAnnotation .popupTriggerArea {
	height: 100%;
	width: 100%;
}

.annotationLayer .popupAnnotation {
	position: absolute;
	font-size: calc(9px * var(--scale-factor));
	pointer-events: none;
	width: -moz-max-content;
	width: max-content;
	max-width: 45%;
	height: auto;
}

.annotationLayer .popup {
	background-color: rgba(255, 255, 153, 1);
	box-shadow: 0 calc(2px * var(--scale-factor)) calc(5px * var(--scale-factor)) rgba(136, 136, 136, 1);
	border-radius: calc(2px * var(--scale-factor));
	outline: 1.5px solid rgb(255, 255, 74);
	padding: calc(6px * var(--scale-factor));
	cursor: pointer;
	font: message-box;
	white-space: normal;
	word-wrap: break-word;
	pointer-events: auto;
}

.annotationLayer .popupAnnotation.focused .popup {
	outline-width: 3px;
}

.annotationLayer .popup * {
	font-size: calc(9px * var(--scale-factor));
}

.annotationLayer .popup > .header {
	display: inline-block;
}

.annotationLayer .popup > .header h1 {
	display: inline;
}

.annotationLayer .popup > .header .popupDate {
	display: inline-block;
	margin-left: calc(5px * var(--scale-factor));
	width: -moz-fit-content;
	width: fit-content;
}

.annotationLayer .popupContent {
	border-top: 1px solid rgba(51, 51, 51, 1);
	margin-top: calc(2px * var(--scale-factor));
	padding-top: calc(2px * var(--scale-factor));
}

.annotationLayer .richText > * {
	white-space: pre-wrap;
	font-size: calc(9px * var(--scale-factor));
}

.annotationLayer .popupTriggerArea {
	cursor: pointer;
}

.annotationLayer section svg {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}

.annotationLayer .annotationTextContent {
	position: absolute;
	width: 100%;
	height: 100%;
	opacity: 0;
	color: transparent;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	pointer-events: none;
}

.annotationLayer .annotationTextContent span {
	width: 100%;
	display: inline-block;
}

.annotationLayer svg.quadrilateralsContainer {
	contain: strict;
	width: 0;
	height: 0;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

:root {
	--xfa-unfocused-field-background: url("data:image/svg+xml;charset=UTF-8,<svg width='1px' height='1px' xmlns='http://www.w3.org/2000/svg'><rect width='100%' height='100%' style='fill:rgba(0, 54, 255, 0.13);'/></svg>");
	--xfa-focus-outline: auto;
}

@media screen and (forced-colors: active) {
	:root {
		--xfa-focus-outline: 2px solid CanvasText;
	}

	.xfaLayer *:required {
		outline: 1.5px solid selectedItem;
	}
}

.xfaLayer {
	background-color: transparent;
}

.xfaLayer .highlight {
	margin: -1px;
	padding: 1px;
	background-color: rgba(239, 203, 237, 1);
	border-radius: 4px;
}

.xfaLayer .highlight.appended {
	position: initial;
}

.xfaLayer .highlight.begin {
	border-radius: 4px 0 0 4px;
}

.xfaLayer .highlight.end {
	border-radius: 0 4px 4px 0;
}

.xfaLayer .highlight.middle {
	border-radius: 0;
}

.xfaLayer .highlight.selected {
	background-color: rgba(203, 223, 203, 1);
}

.xfaPage {
	overflow: hidden;
	position: relative;
}

.xfaContentarea {
	position: absolute;
}

.xfaPrintOnly {
	display: none;
}

.xfaLayer {
	position: absolute;
	text-align: initial;
	top: 0;
	left: 0;
	transform-origin: 0 0;
	line-height: 1.2;
}

.xfaLayer * {
	color: inherit;
	font: inherit;
	font-style: inherit;
	font-weight: inherit;
	font-kerning: inherit;
	letter-spacing: -0.01px;
	text-align: inherit;
	text-decoration: inherit;
	box-sizing: border-box;
	background-color: transparent;
	padding: 0;
	margin: 0;
	pointer-events: auto;
	line-height: inherit;
}

.xfaLayer *:required {
	outline: 1.5px solid red;
}

.xfaLayer div,
.xfaLayer svg,
.xfaLayer svg * {
	pointer-events: none;
}

.xfaLayer a {
	color: blue;
}

.xfaRich li {
	margin-left: 3em;
}

.xfaFont {
	color: black;
	font-weight: normal;
	font-kerning: none;
	font-size: 10px;
	font-style: normal;
	letter-spacing: 0;
	text-decoration: none;
	vertical-align: 0;
}

.xfaCaption {
	overflow: hidden;
	flex: 0 0 auto;
}

.xfaCaptionForCheckButton {
	overflow: hidden;
	flex: 1 1 auto;
}

.xfaLabel {
	height: 100%;
	width: 100%;
}

.xfaLeft {
	display: flex;
	flex-direction: row;
	align-items: center;
}

.xfaRight {
	display: flex;
	flex-direction: row-reverse;
	align-items: center;
}

:is(.xfaLeft, .xfaRight) > :is(.xfaCaption, .xfaCaptionForCheckButton) {
	max-height: 100%;
}

.xfaTop {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

.xfaBottom {
	display: flex;
	flex-direction: column-reverse;
	align-items: flex-start;
}

:is(.xfaTop, .xfaBottom) > :is(.xfaCaption, .xfaCaptionForCheckButton) {
	width: 100%;
}

.xfaBorder {
	background-color: transparent;
	position: absolute;
	pointer-events: none;
}

.xfaWrapped {
	width: 100%;
	height: 100%;
}

:is(.xfaTextfield, .xfaSelect):focus {
	background-image: none;
	background-color: transparent;
	outline: var(--xfa-focus-outline);
	outline-offset: -1px;
}

:is(.xfaCheckbox, .xfaRadio):focus {
	outline: var(--xfa-focus-outline);
}

.xfaTextfield,
.xfaSelect {
	height: 100%;
	width: 100%;
	flex: 1 1 auto;
	border: none;
	resize: none;
	background-image: var(--xfa-unfocused-field-background);
}

.xfaSelect {
	padding-inline: 2px;
}

:is(.xfaTop, .xfaBottom) > :is(.xfaTextfield, .xfaSelect) {
	flex: 0 1 auto;
}

.xfaButton {
	cursor: pointer;
	width: 100%;
	height: 100%;
	border: none;
	text-align: center;
}

.xfaLink {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
}

.xfaCheckbox,
.xfaRadio {
	width: 100%;
	height: 100%;
	flex: 0 0 auto;
	border: none;
}

.xfaRich {
	white-space: pre-wrap;
	width: 100%;
	height: 100%;
}

.xfaImage {
	-o-object-position: left top;
	object-position: left top;
	-o-object-fit: contain;
	object-fit: contain;
	width: 100%;
	height: 100%;
}

.xfaLrTb,
.xfaRlTb,
.xfaTb {
	display: flex;
	flex-direction: column;
	align-items: stretch;
}

.xfaLr {
	display: flex;
	flex-direction: row;
	align-items: stretch;
}

.xfaRl {
	display: flex;
	flex-direction: row-reverse;
	align-items: stretch;
}

.xfaTb > div {
	justify-content: left;
}

.xfaPosition {
	position: relative;
}

.xfaArea {
	position: relative;
}

.xfaValignMiddle {
	display: flex;
	align-items: center;
}

.xfaTable {
	display: flex;
	flex-direction: column;
	align-items: stretch;
}

.xfaTable .xfaRow {
	display: flex;
	flex-direction: row;
	align-items: stretch;
}

.xfaTable .xfaRlRow {
	display: flex;
	flex-direction: row-reverse;
	align-items: stretch;
	flex: 1;
}

.xfaTable .xfaRlRow > div {
	flex: 1;
}

:is(.xfaNonInteractive, .xfaDisabled, .xfaReadOnly) :is(input, textarea) {
	background: initial;
}

@media print {

	.xfaTextfield,
	.xfaSelect {
		background: transparent;
	}

	.xfaSelect {
		-webkit-appearance: none;
		-moz-appearance: none;
		appearance: none;
		text-indent: 1px;
		text-overflow: "";
	}
}

/* Ignored in GECKOVIEW builds: */

:root {
	--outline-width: 2px;
	--outline-color: #0060df;
	--outline-around-width: 1px;
	--outline-around-color: #f0f0f4;
	--hover-outline-around-color: var(--outline-around-color);
	--focus-outline: solid var(--outline-width) var(--outline-color);
	--unfocus-outline: solid var(--outline-width) transparent;
	--focus-outline-around: solid var(--outline-around-width) var(--outline-around-color);
	--hover-outline-color: #8f8f9d;
	--hover-outline: solid var(--outline-width) var(--hover-outline-color);
	--hover-outline-around: solid var(--outline-around-width) var(--hover-outline-around-color);
	--freetext-line-height: 1.35;
	--freetext-padding: 2px;
	--resizer-bg-color: var(--outline-color);
	--resizer-size: 6px;
	--resizer-shift: calc(0px - (var(--outline-width) + var(--resizer-size)) / 2 - var(--outline-around-width));
	--editorFreeText-editing-cursor: text;
	--editorInk-editing-cursor: url(images/cursor-editorInk.svg) 0 16, pointer;

	--alt-text-opacity: 0.8;
	--alt-text-add-image: url(images/altText_add.svg);
	--alt-text-done-image: url(images/altText_done.svg);
	--alt-text-bg-color: rgba(43, 42, 51, var(--alt-text-opacity));
	--alt-text-fg-color: #fbfbfe;
	--alt-text-border-color: var(--alt-text-bg-color);
	--alt-text-hover-bg-color: rgba(82, 82, 94, var(--alt-text-opacity));
	--alt-text-hover-fg-color: var(--alt-text-fg-color);
	--alt-text-hover-border-color: var(--alt-text-hover-bg-color);
	--alt-text-active-bg-color: rgba(91, 91, 102, var(--alt-text-opacity));
	--alt-text-active-fg-color: var(--alt-text-fg-color);
	--alt-text-active-border-color: var(--alt-text-hover-bg-color);
	--alt-text-focus-outline-color: #0060df;
	--alt-text-focus-border-color: #f0f0f4;
	--alt-text-shadow: 0 2px 6px 0 rgba(28, 27, 34, 0.5);
}

@media (-webkit-min-device-pixel-ratio: 1.1), (min-resolution: 1.1dppx) {
	:root {
		--editorFreeText-editing-cursor: url(images/cursor-editorFreeText.svg) 0 16,
			text;
	}
}

@media screen and (forced-colors: active) {
	:root {
		--outline-color: CanvasText;
		--outline-around-color: ButtonFace;
		--resizer-bg-color: ButtonText;
		--hover-outline-color: Highlight;
		--hover-outline-around-color: SelectedItemText;

		--alt-text-bg-color: Canvas;
		--alt-text-fg-color: ButtonText;
		--alt-text-border-color: ButtonText;
		--alt-text-hover-bg-color: Canvas;
		--alt-text-hover-fg-color: SelectedItem;
		--alt-text-hover-border-color: SelectedItem;
		--alt-text-active-bg-color: ButtonFace;
		--alt-text-active-fg-color: SelectedItem;
		--alt-text-active-border-color: ButtonText;
		--alt-text-focus-outline-color: CanvasText;
		--alt-text-focus-border-color: ButtonText;
		--alt-text-shadow: none;
		--alt-text-opacity: 1;
	}
}

[data-editor-rotation="90"] {
	transform: rotate(90deg);
}

[data-editor-rotation="180"] {
	transform: rotate(180deg);
}

[data-editor-rotation="270"] {
	transform: rotate(270deg);
}

.annotationEditorLayer {
	background: transparent;
	position: absolute;
	inset: 0;
	font-size: calc(100px * var(--scale-factor));
	transform-origin: 0 0;
	cursor: auto;
	z-index: 4;
}

.annotationEditorLayer.waiting {
	content: "";
	cursor: wait;
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
}

.annotationEditorLayer.freeTextEditing {
	cursor: var(--editorFreeText-editing-cursor);
}

.annotationEditorLayer.inkEditing {
	cursor: var(--editorInk-editing-cursor);
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) {
	position: absolute;
	background: transparent;
	z-index: 1;
	transform-origin: 0 0;
	cursor: auto;
	max-width: 100%;
	max-height: 100%;
	border: var(--unfocus-outline);
}

.annotationEditorLayer .draggable.selectedEditor:is(.freeTextEditor, .inkEditor, .stampEditor) {
	cursor: move;
}

.annotationEditorLayer .selectedEditor:is(.freeTextEditor, .inkEditor, .stampEditor) {
	border: var(--focus-outline);
	outline: var(--focus-outline-around);
}

.annotationEditorLayer .selectedEditor:is(.freeTextEditor, .inkEditor, .stampEditor)::before {
	/*
        This is a workaround for the lack of support for stripes(...) (see
        https://drafts.csswg.org/css-images-4/#stripes).
        The outline should be composed of 1px white, 2px blue and 1px white.
        This could be achieved in different ways:
          - using a linear-gradient;
          - using a box-shadow;
          - using an outline on the selected element and an outline+border on
            the ::before pseudo-element.
        All these options lead to incorrect rendering likely due to rounding
        issues.
        That said it doesn't mean that the current is ideal, but it's the best
        we could come up with for the moment.
        One drawback of this approach is that we use a border on the selected
        element which means that we must take care of it when positioning the
        div in js (see AnnotationEditor._borderLineWidth in editor.js).
      */
	content: "";
	position: absolute;
	inset: 0;
	border: var(--focus-outline-around);
	pointer-events: none;
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor):hover:not(.selectedEditor) {
	border: var(--hover-outline);
	outline: var(--hover-outline-around);
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor):hover:not(.selectedEditor)::before {
	content: "";
	position: absolute;
	inset: 0;
	border: var(--focus-outline-around);
}

.annotationEditorLayer .freeTextEditor {
	padding: calc(var(--freetext-padding) * var(--scale-factor));
	width: auto;
	height: auto;
	touch-action: none;
}

.annotationEditorLayer .freeTextEditor .internal {
	background: transparent;
	border: none;
	inset: 0;
	overflow: visible;
	white-space: nowrap;
	font: 10px sans-serif;
	line-height: var(--freetext-line-height);
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
}

.annotationEditorLayer .freeTextEditor .overlay {
	position: absolute;
	display: none;
	background: transparent;
	inset: 0;
	width: 100%;
	height: 100%;
}

.annotationEditorLayer .freeTextEditor .overlay.enabled {
	display: block;
}

.annotationEditorLayer .freeTextEditor .internal:empty::before {
	content: attr(default-content);
	color: gray;
}

.annotationEditorLayer .freeTextEditor .internal:focus {
	outline: none;
	-webkit-user-select: auto;
	-moz-user-select: auto;
	user-select: auto;
}

.annotationEditorLayer .inkEditor {
	width: 100%;
	height: 100%;
}

.annotationEditorLayer .inkEditor.editing {
	cursor: inherit;
}

.annotationEditorLayer .inkEditor .inkEditorCanvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	touch-action: none;
}

.annotationEditorLayer .stampEditor {
	width: auto;
	height: auto;
}

.annotationEditorLayer .stampEditor canvas {
	width: 100%;
	height: 100%;
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers {
	position: absolute;
	inset: 0;
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers.hidden {
	display: none;
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer {
	width: var(--resizer-size);
	height: var(--resizer-size);
	background: content-box var(--resizer-bg-color);
	border: var(--focus-outline-around);
	border-radius: 2px;
	position: absolute;
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer.topLeft {
	top: var(--resizer-shift);
	left: var(--resizer-shift);
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer.topMiddle {
	top: var(--resizer-shift);
	left: calc(50% + var(--resizer-shift));
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer.topRight {
	top: var(--resizer-shift);
	right: var(--resizer-shift);
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer.middleRight {
	top: calc(50% + var(--resizer-shift));
	right: var(--resizer-shift);
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer.bottomRight {
	bottom: var(--resizer-shift);
	right: var(--resizer-shift);
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer.bottomMiddle {
	bottom: var(--resizer-shift);
	left: calc(50% + var(--resizer-shift));
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer.bottomLeft {
	bottom: var(--resizer-shift);
	left: var(--resizer-shift);
}

.annotationEditorLayer :is(.freeTextEditor, .inkEditor, .stampEditor) > .resizers > .resizer.middleLeft {
	top: calc(50% + var(--resizer-shift));
	left: var(--resizer-shift);
}

.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.topLeft,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.topLeft,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.topLeft,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.topLeft,
.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.bottomRight,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.bottomRight,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.bottomRight,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.bottomRight {
	cursor: nwse-resize;
}

.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.topMiddle,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.topMiddle,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.topMiddle,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.topMiddle,
.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.bottomMiddle,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.bottomMiddle,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.bottomMiddle,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.bottomMiddle {
	cursor: ns-resize;
}

.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.topRight,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.topRight,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.topRight,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.topRight,
.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.bottomLeft,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.bottomLeft,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.bottomLeft,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.bottomLeft {
	cursor: nesw-resize;
}

.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.middleRight,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.middleRight,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.middleRight,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.middleRight,
.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.middleLeft,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.middleLeft,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.middleLeft,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.middleLeft {
	cursor: ew-resize;
}

.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.topLeft,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.topLeft,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.topLeft,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.topLeft,
.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.bottomRight,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.bottomRight,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.bottomRight,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.bottomRight {
	cursor: nesw-resize;
}

.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.topMiddle,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.topMiddle,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.topMiddle,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.topMiddle,
.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.bottomMiddle,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.bottomMiddle,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.bottomMiddle,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.bottomMiddle {
	cursor: ew-resize;
}

.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.topRight,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.topRight,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.topRight,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.topRight,
.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.bottomLeft,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.bottomLeft,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.bottomLeft,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.bottomLeft {
	cursor: nwse-resize;
}

.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.middleRight,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.middleRight,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.middleRight,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.middleRight,
.annotationEditorLayer[data-main-rotation="0"] :is([data-editor-rotation="90"], [data-editor-rotation="270"]) > .resizers > .resizer.middleLeft,
.annotationEditorLayer[data-main-rotation="90"] :is([data-editor-rotation="0"], [data-editor-rotation="180"]) > .resizers > .resizer.middleLeft,
.annotationEditorLayer[data-main-rotation="180"] :is([data-editor-rotation="270"], [data-editor-rotation="90"]) > .resizers > .resizer.middleLeft,
.annotationEditorLayer[data-main-rotation="270"] :is([data-editor-rotation="180"], [data-editor-rotation="0"]) > .resizers > .resizer.middleLeft {
	cursor: ns-resize;
}

.annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="90"],
	[data-main-rotation="90"] [data-editor-rotation="0"],
	[data-main-rotation="180"] [data-editor-rotation="270"],
	[data-main-rotation="270"] [data-editor-rotation="180"]) .altText {
	rotate: 270deg;
}

[dir="ltr"] .annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="90"],
	[data-main-rotation="90"] [data-editor-rotation="0"],
	[data-main-rotation="180"] [data-editor-rotation="270"],
	[data-main-rotation="270"] [data-editor-rotation="180"]) .altText {
	inset-inline-start: calc(100% - 8px);
}

[dir="ltr"] .annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="90"],
	[data-main-rotation="90"] [data-editor-rotation="0"],
	[data-main-rotation="180"] [data-editor-rotation="270"],
	[data-main-rotation="270"] [data-editor-rotation="180"]) .altText.small {
	inset-inline-start: calc(100% + 8px);
	inset-block-start: 100%;
}

[dir="rtl"] .annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="90"],
	[data-main-rotation="90"] [data-editor-rotation="0"],
	[data-main-rotation="180"] [data-editor-rotation="270"],
	[data-main-rotation="270"] [data-editor-rotation="180"]) .altText {
	inset-block-end: calc(100% - 8px);
}

[dir="rtl"] .annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="90"],
	[data-main-rotation="90"] [data-editor-rotation="0"],
	[data-main-rotation="180"] [data-editor-rotation="270"],
	[data-main-rotation="270"] [data-editor-rotation="180"]) .altText.small {
	inset-inline-start: -8px;
	inset-block-start: 0;
}

.annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="180"],
	[data-main-rotation="90"] [data-editor-rotation="90"],
	[data-main-rotation="180"] [data-editor-rotation="0"],
	[data-main-rotation="270"] [data-editor-rotation="270"]) .altText {
	rotate: 180deg;

	inset-block-end: calc(100% - 8px);
	inset-inline-start: calc(100% - 8px);
}

.annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="180"],
	[data-main-rotation="90"] [data-editor-rotation="90"],
	[data-main-rotation="180"] [data-editor-rotation="0"],
	[data-main-rotation="270"] [data-editor-rotation="270"]) .altText.small {
	inset-inline-start: 100%;
	inset-block-start: -8px;
}

.annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="270"],
	[data-main-rotation="90"] [data-editor-rotation="180"],
	[data-main-rotation="180"] [data-editor-rotation="90"],
	[data-main-rotation="270"] [data-editor-rotation="0"]) .altText {
	rotate: 90deg;
}

[dir="ltr"] .annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="270"],
	[data-main-rotation="90"] [data-editor-rotation="180"],
	[data-main-rotation="180"] [data-editor-rotation="90"],
	[data-main-rotation="270"] [data-editor-rotation="0"]) .altText {
	inset-block-end: calc(100% - 8px);
}

[dir="ltr"] .annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="270"],
	[data-main-rotation="90"] [data-editor-rotation="180"],
	[data-main-rotation="180"] [data-editor-rotation="90"],
	[data-main-rotation="270"] [data-editor-rotation="0"]) .altText.small {
	inset-inline-start: -8px;
	inset-block-start: 0;
}

[dir="rtl"] .annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="270"],
	[data-main-rotation="90"] [data-editor-rotation="180"],
	[data-main-rotation="180"] [data-editor-rotation="90"],
	[data-main-rotation="270"] [data-editor-rotation="0"]) .altText {
	inset-inline-start: calc(100% - 8px);
}

[dir="rtl"] .annotationEditorLayer :is([data-main-rotation="0"] [data-editor-rotation="270"],
	[data-main-rotation="90"] [data-editor-rotation="180"],
	[data-main-rotation="180"] [data-editor-rotation="90"],
	[data-main-rotation="270"] [data-editor-rotation="0"]) .altText.small {
	inset-inline-start: calc(100% + 8px);
	inset-block-start: 100%;
}

.altText {
	display: flex;
	align-items: center;
	justify-content: center;
	padding-inline: 4px;
	width: auto;
	height: 24px;
	min-width: 88px;
	z-index: 1;
	pointer-events: all;

	color: var(--alt-text-fg-color);
	font: menu;
	font-size: 12px;
	border-radius: 4px;
	border: 1px solid var(--alt-text-border-color);
	background-color: var(--alt-text-bg-color);
	box-shadow: var(--alt-text-shadow);

	position: absolute;
	inset-block-end: 8px;
	inset-inline-start: 8px;
}

[dir="ltr"] .altText {
	transform-origin: 0 100%;
}

[dir="rtl"] .altText {
	transform-origin: 100% 100%;
}

.altText.small {

	inset-block-end: unset;
	inset-inline-start: 0;
	inset-block-start: calc(100% + 8px);
}

[dir="ltr"] .altText.small {
	transform-origin: 0 0;
}

[dir="rtl"] .altText.small {
	transform-origin: 100% 0;
}

.altText:hover {
	background-color: var(--alt-text-hover-bg-color);
	border-color: var(--alt-text-hover-border-color);
	color: var(--alt-text-hover-fg-color);
	cursor: pointer;
}

.altText:hover::before {
	background-color: var(--alt-text-hover-fg-color);
}

.altText:active {
	background-color: var(--alt-text-active-bg-color);
	border-color: var(--alt-text-active-border-color);
	color: var(--alt-text-active-fg-color);
}

.altText:active::before {
	background-color: var(--alt-text-active-fg-color);
}

.altText:focus-visible {
	outline: 2px solid var(--alt-text-focus-outline-color);
	border-color: var(--alt-text-focus-border-color);
}

.altText::before {
	content: "";
	-webkit-mask-image: var(--alt-text-add-image);
	mask-image: var(--alt-text-add-image);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center;
	mask-position: center;
	display: inline-block;
	width: 12px;
	height: 13px;
	background-color: var(--alt-text-fg-color);
	margin-inline-end: 4px;
}

.altText.done::before {
	-webkit-mask-image: var(--alt-text-done-image);
	mask-image: var(--alt-text-done-image);
}

.altText .tooltip {
	display: none;
}

.altText .tooltip.show {
	--alt-text-tooltip-bg: #f0f0f4;
	--alt-text-tooltip-fg: #15141a;
	--alt-text-tooltip-border: #8f8f9d;
	--alt-text-tooltip-shadow: 0px 2px 6px 0px rgba(58, 57, 68, 0.2);

	display: inline-flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	position: absolute;
	top: calc(100% + 2px);
	inset-inline-start: 0;
	padding-block: 2px 3px;
	padding-inline: 3px;
	max-width: 300px;
	width: -moz-max-content;
	width: max-content;
	height: auto;
	font-size: 12px;

	border: 0.5px solid var(--alt-text-tooltip-border);
	background: var(--alt-text-tooltip-bg);
	box-shadow: var(--alt-text-tooltip-shadow);
	color: var(--alt-text-tooltip-fg);

	pointer-events: none;
}

@media (prefers-color-scheme: dark) {

	.altText .tooltip.show {
		--alt-text-tooltip-bg: #1c1b22;
		--alt-text-tooltip-fg: #fbfbfe;
		--alt-text-tooltip-shadow: 0px 2px 6px 0px #15141a;
	}
}

@media screen and (forced-colors: active) {

	.altText .tooltip.show {
		--alt-text-tooltip-bg: Canvas;
		--alt-text-tooltip-fg: CanvasText;
		--alt-text-tooltip-border: CanvasText;
		--alt-text-tooltip-shadow: none;
	}
}

#altTextDialog {
	--dialog-bg-color: white;
	--dialog-border-color: white;
	--dialog-shadow: 0 2px 14px 0 rgba(58, 57, 68, 0.2);
	--text-primary-color: #15141a;
	--text-secondary-color: #5b5b66;
	--hover-filter: brightness(0.9);
	--focus-ring-color: #0060df;
	--focus-ring-outline: 2px solid var(--focus-ring-color);

	--textarea-border-color: #8f8f9d;
	--textarea-bg-color: white;
	--textarea-fg-color: var(--text-secondary-color);

	--radio-bg-color: #f0f0f4;
	--radio-checked-bg-color: #fbfbfe;
	--radio-border-color: #8f8f9d;
	--radio-checked-border-color: #0060df;

	--button-cancel-bg-color: #f0f0f4;
	--button-cancel-fg-color: var(--text-primary-color);
	--button-cancel-border-color: var(--button-cancel-bg-color);
	--button-cancel-hover-bg-color: var(--button-cancel-bg-color);
	--button-cancel-hover-fg-color: var(--button-cancel-fg-color);
	--button-cancel-hover-border-color: var(--button-cancel-hover-bg-color);

	--button-save-bg-color: #0060df;
	--button-save-fg-color: #fbfbfe;
	--button-save-hover-bg-color: var(--button-save-bg-color);
	--button-save-hover-fg-color: var(--button-save-fg-color);
	--button-save-hover-border-color: var(--button-save-hover-bg-color);
	--button-save-disabled-bg-color: var(--button-save-bg-color);
	--button-save-disabled-fg-color: var(--button-save-fg-color);
	--button-save-disabled-opacity: 0.4;

	font: message-box;
	font-size: 13px;
	font-weight: 400;
	line-height: 150%;
	border-radius: 4px;
	padding: 12px 16px;
	border: 1px solid var(--dialog-border-color);
	background: var(--dialog-bg-color);
	color: var(--text-primary-color);
	box-shadow: var(--dialog-shadow);
}

@media (prefers-color-scheme: dark) {

	#altTextDialog {
		--dialog-bg-color: #1c1b22;
		--dialog-border-color: #1c1b22;
		--dialog-shadow: 0 2px 14px 0 #15141a;
		--text-primary-color: #fbfbfe;
		--text-secondary-color: #cfcfd8;
		--focus-ring-color: #00ddff;
		--hover-filter: brightness(1.4);

		--textarea-bg-color: #42414d;

		--radio-bg-color: #2b2a33;
		--radio-checked-bg-color: #15141a;
		--radio-checked-border-color: #00ddff;

		--button-cancel-bg-color: #2b2a33;
		--button-save-bg-color: #00ddff;
		--button-save-fg-color: #15141a;
	}
}

@media screen and (forced-colors: active) {

	#altTextDialog {
		--dialog-bg-color: Canvas;
		--dialog-border-color: CanvasText;
		--dialog-shadow: none;
		--text-primary-color: CanvasText;
		--text-secondary-color: CanvasText;
		--hover-filter: none;
		--focus-ring-color: ButtonBorder;

		--textarea-border-color: ButtonBorder;
		--textarea-bg-color: Field;
		--textarea-fg-color: ButtonText;

		--radio-bg-color: ButtonFace;
		--radio-checked-bg-color: ButtonFace;
		--radio-border-color: ButtonText;
		--radio-checked-border-color: ButtonText;

		--button-cancel-bg-color: ButtonFace;
		--button-cancel-fg-color: ButtonText;
		--button-cancel-border-color: ButtonText;
		--button-cancel-hover-bg-color: AccentColor;
		--button-cancel-hover-fg-color: AccentColorText;

		--button-save-bg-color: ButtonText;
		--button-save-fg-color: ButtonFace;
		--button-save-hover-bg-color: AccentColor;
		--button-save-hover-fg-color: AccentColorText;
		--button-save-disabled-bg-color: GrayText;
		--button-save-disabled-fg-color: Canvas;
		--button-save-disabled-opacity: 1;
	}
}

#altTextDialog::backdrop {
	/* This is needed to avoid to darken the image the user want to describe. */
	-webkit-mask: url(#alttext-manager-mask);
	mask: url(#alttext-manager-mask);
}

#altTextDialog.positioned {
	margin: 0;
}

#altTextDialog #altTextContainer {
	width: 300px;
	height: -moz-fit-content;
	height: fit-content;
	display: inline-flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 16px;
}

#altTextDialog #altTextContainer *:focus-visible {
	outline: var(--focus-ring-outline);
	outline-offset: 2px;
}

#altTextDialog #altTextContainer .radio {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 4px;
}

#altTextDialog #altTextContainer .radio .radioButton {
	display: flex;
	gap: 8px;
	align-self: stretch;
	align-items: center;
}

#altTextDialog #altTextContainer .radio .radioButton input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	box-sizing: border-box;
	width: 16px;
	height: 16px;
	border-radius: 50%;
	background-color: var(--radio-bg-color);
	border: 1px solid var(--radio-border-color);
}

#altTextDialog #altTextContainer .radio .radioButton input:hover {
	filter: var(--hover-filter);
}

#altTextDialog #altTextContainer .radio .radioButton input:checked {
	background-color: var(--radio-checked-bg-color);
	border: 4px solid var(--radio-checked-border-color);
}

#altTextDialog #altTextContainer .radio .radioLabel {
	display: flex;
	padding-inline-start: 24px;
	align-items: flex-start;
	gap: 10px;
	align-self: stretch;
}

#altTextDialog #altTextContainer .radio .radioLabel span {
	flex: 1 0 0;
	font-size: 11px;
	color: var(--text-secondary-color);
}

#altTextDialog #altTextContainer #overallDescription {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 4px;
	align-self: stretch;
}

#altTextDialog #altTextContainer #overallDescription span {
	align-self: stretch;
}

#altTextDialog #altTextContainer #overallDescription .title {
	font-size: 13px;
	font-style: normal;
	font-weight: 590;
}

#altTextDialog #altTextContainer #addDescription {
	display: flex;
	flex-direction: column;
	align-items: stretch;
	gap: 8px;
}

#altTextDialog #altTextContainer #addDescription .descriptionArea {
	flex: 1;
	padding-inline: 24px 10px;
}

#altTextDialog #altTextContainer #addDescription .descriptionArea textarea {
	font: inherit;
	width: 100%;
	min-height: 75px;
	padding: 8px;
	resize: none;
	margin: 0;
	box-sizing: border-box;
	border-radius: 4px;
	border: 1px solid var(--textarea-border-color);
	background: var(--textarea-bg-color);
	color: var(--textarea-fg-color);
}

#altTextDialog #altTextContainer #addDescription .descriptionArea textarea:focus {
	outline-offset: 0;
	border-color: transparent;
}

#altTextDialog #altTextContainer #addDescription .descriptionArea textarea:disabled {
	pointer-events: none;
	opacity: 0.4;
}

#altTextDialog #altTextContainer #buttons {
	display: flex;
	justify-content: flex-end;
	align-items: flex-start;
	gap: 8px;
	align-self: stretch;
}

#altTextDialog #altTextContainer #buttons button {
	border-radius: 4px;
	border: 1px solid;
	font: menu;
	font-weight: 600;
	padding: 4px 16px;
	width: auto;
	height: 32px;
}

#altTextDialog #altTextContainer #buttons button:hover {
	cursor: pointer;
	filter: var(--hover-filter);
}

#altTextDialog #altTextContainer #buttons button#altTextCancel {
	color: var(--button-cancel-fg-color);
	background-color: var(--button-cancel-bg-color);
	border-color: var(--button-cancel-border-color);
}

#altTextDialog #altTextContainer #buttons button#altTextCancel:hover {
	color: var(--button-cancel-hover-fg-color);
	background-color: var(--button-cancel-hover-bg-color);
	border-color: var(--button-cancel-hover-border-color);
}

#altTextDialog #altTextContainer #buttons button#altTextSave {
	color: var(--button-save-hover-fg-color);
	background-color: var(--button-save-hover-bg-color);
	border-color: var(--button-save-hover-border-color);
	opacity: 1;
}

#altTextDialog #altTextContainer #buttons button#altTextSave:hover {
	color: var(--button-save-hover-fg-color);
	background-color: var(--button-save-hover-bg-color);
	border-color: var(--button-save-hover-border-color);
}

#altTextDialog #altTextContainer #buttons button#altTextSave:disabled {
	color: var(--button-save-disabled-fg-color);
	background-color: var(--button-save-disabled-bg-color);
	opacity: var(--button-save-disabled-opacity);
	pointer-events: none;
}

:root {
	--viewer-container-height: 0;
	--pdfViewer-padding-bottom: 0;
	--page-margin: 1px auto -8px;
	--page-border: 9px solid transparent;
	--spreadHorizontalWrapped-margin-LR: -3.5px;
	--loading-icon-delay: 400ms;
}

@media screen and (forced-colors: active) {
	:root {
		--pdfViewer-padding-bottom: 9px;
		--page-margin: 8px auto -1px;
		--page-border: 1px solid CanvasText;
		--spreadHorizontalWrapped-margin-LR: 3.5px;
	}
}

[data-main-rotation="90"] {
	transform: rotate(90deg) translateY(-100%);
}

[data-main-rotation="180"] {
	transform: rotate(180deg) translate(-100%, -100%);
}

[data-main-rotation="270"] {
	transform: rotate(270deg) translateX(-100%);
}

#hiddenCopyElement {
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 0;
	display: none;
}

.pdfViewer {
	/* Define this variable here and not in :root to avoid to reflow all the UI
     when scaling (see #15929). */
	--scale-factor: 1;

	padding-bottom: var(--pdfViewer-padding-bottom);
}

.pdfViewer .canvasWrapper {
	overflow: hidden;
	width: 100%;
	height: 100%;
	z-index: 1;
}

.pdfViewer .page {
	direction: ltr;
	width: 816px;
	height: 1056px;
	margin: var(--page-margin);
	position: relative;
	overflow: visible;
	border: var(--page-border);
	background-clip: content-box;
	background-color: rgba(255, 255, 255, 1);
}

.pdfViewer .dummyPage {
	position: relative;
	width: 0;
	height: var(--viewer-container-height);
}

.pdfViewer.noUserSelect {
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
}

.pdfViewer.removePageBorders .page {
	margin: 0 auto 10px;
	border: none;
}

.pdfViewer:is(.scrollHorizontal, .scrollWrapped),
.spread {
	margin-inline: 3.5px;
	text-align: center;
}

.pdfViewer.scrollHorizontal,
.spread {
	white-space: nowrap;
}

.pdfViewer.removePageBorders,
.pdfViewer:is(.scrollHorizontal, .scrollWrapped) .spread {
	margin-inline: 0;
}

.spread :is(.page, .dummyPage),
.pdfViewer:is(.scrollHorizontal, .scrollWrapped) :is(.page, .spread) {
	display: inline-block;
	vertical-align: middle;
}

.spread .page,
.pdfViewer:is(.scrollHorizontal, .scrollWrapped) .page {
	margin-inline: var(--spreadHorizontalWrapped-margin-LR);
}

.pdfViewer.removePageBorders .spread .page,
.pdfViewer.removePageBorders:is(.scrollHorizontal, .scrollWrapped) .page {
	margin-inline: 5px;
}

.pdfViewer .page canvas {
	margin: 0;
	display: block;
}

.pdfViewer .page canvas .structTree {
	contain: strict;
}

.pdfViewer .page canvas[hidden] {
	display: none;
}

.pdfViewer .page canvas[zooming] {
	width: 100%;
	height: 100%;
}

.pdfViewer .page.loadingIcon::after {
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	width: 100%;
	height: 100%;
	background: url("images/loading-icon.gif") center no-repeat;
	display: none;
	/* Using a delay with background-image doesn't work,
     consequently we use the display. */
	transition-property: display;
	transition-delay: var(--loading-icon-delay);
	z-index: 5;
	contain: strict;
}

.pdfViewer .page.loading::after {
	display: block;
}

.pdfViewer .page:not(.loading)::after {
	transition-property: none;
	display: none;
}

.pdfPresentationMode .pdfViewer {
	padding-bottom: 0;
}

.pdfPresentationMode .spread {
	margin: 0;
}

.pdfPresentationMode .pdfViewer .page {
	margin: 0 auto;
	border: 2px solid transparent;
}

:root {
	--dir-factor: 1;
	--inline-start: left;
	--inline-end: right;

	--sidebar-width: 200px;
	--sidebar-transition-duration: 200ms;
	--sidebar-transition-timing-function: ease;

	--toolbar-icon-opacity: 0.7;
	--doorhanger-icon-opacity: 0.9;

	--main-color: rgba(12, 12, 13, 1);
	--body-bg-color: rgba(212, 212, 215, 1);
	--progressBar-color: rgba(10, 132, 255, 1);
	--progressBar-bg-color: rgba(221, 221, 222, 1);
	--progressBar-blend-color: rgba(116, 177, 239, 1);
	--scrollbar-color: auto;
	--scrollbar-bg-color: auto;
	--toolbar-icon-bg-color: rgba(0, 0, 0, 1);
	--toolbar-icon-hover-bg-color: rgba(0, 0, 0, 1);

	--sidebar-narrow-bg-color: rgba(212, 212, 215, 0.9);
	--sidebar-toolbar-bg-color: rgba(245, 246, 247, 1);
	--toolbar-bg-color: rgba(249, 249, 250, 1);
	--toolbar-border-color: rgba(184, 184, 184, 1);
	--toolbar-box-shadow: 0 1px 0 var(--toolbar-border-color);
	--toolbar-border-bottom: none;
	--toolbarSidebar-box-shadow: inset calc(-1px * var(--dir-factor)) 0 0 rgba(0, 0, 0, 0.25),
		0 1px 0 rgba(0, 0, 0, 0.15), 0 0 1px rgba(0, 0, 0, 0.1);
	--toolbarSidebar-border-bottom: none;
	--button-hover-color: rgba(221, 222, 223, 1);
	--toggled-btn-color: rgba(0, 0, 0, 1);
	--toggled-btn-bg-color: rgba(0, 0, 0, 0.3);
	--toggled-hover-active-btn-color: rgba(0, 0, 0, 0.4);
	--toggled-hover-btn-outline: none;
	--dropdown-btn-bg-color: rgba(215, 215, 219, 1);
	--dropdown-btn-border: none;
	--separator-color: rgba(0, 0, 0, 0.3);
	--field-color: rgba(6, 6, 6, 1);
	--field-bg-color: rgba(255, 255, 255, 1);
	--field-border-color: rgba(187, 187, 188, 1);
	--treeitem-color: rgba(0, 0, 0, 0.8);
	--treeitem-bg-color: rgba(0, 0, 0, 0.15);
	--treeitem-hover-color: rgba(0, 0, 0, 0.9);
	--treeitem-selected-color: rgba(0, 0, 0, 0.9);
	--treeitem-selected-bg-color: rgba(0, 0, 0, 0.25);
	--thumbnail-hover-color: rgba(0, 0, 0, 0.1);
	--thumbnail-selected-color: rgba(0, 0, 0, 0.2);
	--doorhanger-bg-color: rgba(255, 255, 255, 1);
	--doorhanger-border-color: rgba(12, 12, 13, 0.2);
	--doorhanger-hover-color: rgba(12, 12, 13, 1);
	--doorhanger-hover-bg-color: rgba(237, 237, 237, 1);
	--doorhanger-separator-color: rgba(222, 222, 222, 1);
	--dialog-button-border: none;
	--dialog-button-bg-color: rgba(12, 12, 13, 0.1);
	--dialog-button-hover-bg-color: rgba(12, 12, 13, 0.3);

	--loading-icon: url(images/loading.svg);
	--treeitem-expanded-icon: url(images/treeitem-expanded.svg);
	--treeitem-collapsed-icon: url(images/treeitem-collapsed.svg);
	--toolbarButton-editorFreeText-icon: url(images/toolbarButton-editorFreeText.svg);
	--toolbarButton-editorInk-icon: url(images/toolbarButton-editorInk.svg);
	--toolbarButton-editorStamp-icon: url(images/toolbarButton-editorStamp.svg);
	--toolbarButton-menuArrow-icon: url(images/toolbarButton-menuArrow.svg);
	--toolbarButton-sidebarToggle-icon: url(images/toolbarButton-sidebarToggle.svg);
	--toolbarButton-secondaryToolbarToggle-icon: url(images/toolbarButton-secondaryToolbarToggle.svg);
	--toolbarButton-pageUp-icon: url(images/toolbarButton-pageUp.svg);
	--toolbarButton-pageDown-icon: url(images/toolbarButton-pageDown.svg);
	--toolbarButton-zoomOut-icon: url(images/toolbarButton-zoomOut.svg);
	--toolbarButton-zoomIn-icon: url(images/toolbarButton-zoomIn.svg);
	--toolbarButton-presentationMode-icon: url(images/toolbarButton-presentationMode.svg);
	--toolbarButton-print-icon: url(images/toolbarButton-print.svg);
	--toolbarButton-openFile-icon: url(images/toolbarButton-openFile.svg);
	--toolbarButton-download-icon: url(images/toolbarButton-download.svg);
	--toolbarButton-bookmark-icon: url(images/toolbarButton-bookmark.svg);
	--toolbarButton-viewThumbnail-icon: url(images/toolbarButton-viewThumbnail.svg);
	--toolbarButton-viewOutline-icon: url(images/toolbarButton-viewOutline.svg);
	--toolbarButton-viewAttachments-icon: url(images/toolbarButton-viewAttachments.svg);
	--toolbarButton-viewLayers-icon: url(images/toolbarButton-viewLayers.svg);
	--toolbarButton-currentOutlineItem-icon: url(images/toolbarButton-currentOutlineItem.svg);
	--toolbarButton-search-icon: url(images/toolbarButton-search.svg);
	--findbarButton-previous-icon: url(images/findbarButton-previous.svg);
	--findbarButton-next-icon: url(images/findbarButton-next.svg);
	--secondaryToolbarButton-firstPage-icon: url(images/secondaryToolbarButton-firstPage.svg);
	--secondaryToolbarButton-lastPage-icon: url(images/secondaryToolbarButton-lastPage.svg);
	--secondaryToolbarButton-rotateCcw-icon: url(images/secondaryToolbarButton-rotateCcw.svg);
	--secondaryToolbarButton-rotateCw-icon: url(images/secondaryToolbarButton-rotateCw.svg);
	--secondaryToolbarButton-selectTool-icon: url(images/secondaryToolbarButton-selectTool.svg);
	--secondaryToolbarButton-handTool-icon: url(images/secondaryToolbarButton-handTool.svg);
	--secondaryToolbarButton-scrollPage-icon: url(images/secondaryToolbarButton-scrollPage.svg);
	--secondaryToolbarButton-scrollVertical-icon: url(images/secondaryToolbarButton-scrollVertical.svg);
	--secondaryToolbarButton-scrollHorizontal-icon: url(images/secondaryToolbarButton-scrollHorizontal.svg);
	--secondaryToolbarButton-scrollWrapped-icon: url(images/secondaryToolbarButton-scrollWrapped.svg);
	--secondaryToolbarButton-spreadNone-icon: url(images/secondaryToolbarButton-spreadNone.svg);
	--secondaryToolbarButton-spreadOdd-icon: url(images/secondaryToolbarButton-spreadOdd.svg);
	--secondaryToolbarButton-spreadEven-icon: url(images/secondaryToolbarButton-spreadEven.svg);
	--secondaryToolbarButton-documentProperties-icon: url(images/secondaryToolbarButton-documentProperties.svg);
	--editorParams-stampAddImage-icon: url(images/toolbarButton-zoomIn.svg);
}

[dir="rtl"]:root {
	--dir-factor: -1;
	--inline-start: right;
	--inline-end: left;
}

@media (prefers-color-scheme: dark) {
	:root {
		--main-color: rgba(249, 249, 250, 1);
		--body-bg-color: rgba(42, 42, 46, 1);
		--progressBar-color: rgba(0, 96, 223, 1);
		--progressBar-bg-color: rgba(40, 40, 43, 1);
		--progressBar-blend-color: rgba(20, 68, 133, 1);
		--scrollbar-color: rgba(121, 121, 123, 1);
		--scrollbar-bg-color: rgba(35, 35, 39, 1);
		--toolbar-icon-bg-color: rgba(255, 255, 255, 1);
		--toolbar-icon-hover-bg-color: rgba(255, 255, 255, 1);

		--sidebar-narrow-bg-color: rgba(42, 42, 46, 0.9);
		--sidebar-toolbar-bg-color: rgba(50, 50, 52, 1);
		--toolbar-bg-color: rgba(56, 56, 61, 1);
		--toolbar-border-color: rgba(12, 12, 13, 1);
		--button-hover-color: rgba(102, 102, 103, 1);
		--toggled-btn-color: rgba(255, 255, 255, 1);
		--toggled-btn-bg-color: rgba(0, 0, 0, 0.3);
		--toggled-hover-active-btn-color: rgba(0, 0, 0, 0.4);
		--dropdown-btn-bg-color: rgba(74, 74, 79, 1);
		--separator-color: rgba(0, 0, 0, 0.3);
		--field-color: rgba(250, 250, 250, 1);
		--field-bg-color: rgba(64, 64, 68, 1);
		--field-border-color: rgba(115, 115, 115, 1);
		--treeitem-color: rgba(255, 255, 255, 0.8);
		--treeitem-bg-color: rgba(255, 255, 255, 0.15);
		--treeitem-hover-color: rgba(255, 255, 255, 0.9);
		--treeitem-selected-color: rgba(255, 255, 255, 0.9);
		--treeitem-selected-bg-color: rgba(255, 255, 255, 0.25);
		--thumbnail-hover-color: rgba(255, 255, 255, 0.1);
		--thumbnail-selected-color: rgba(255, 255, 255, 0.2);
		--doorhanger-bg-color: rgba(74, 74, 79, 1);
		--doorhanger-border-color: rgba(39, 39, 43, 1);
		--doorhanger-hover-color: rgba(249, 249, 250, 1);
		--doorhanger-hover-bg-color: rgba(93, 94, 98, 1);
		--doorhanger-separator-color: rgba(92, 92, 97, 1);
		--dialog-button-bg-color: rgba(92, 92, 97, 1);
		--dialog-button-hover-bg-color: rgba(115, 115, 115, 1);

		/* This image is used in <input> elements, which unfortunately means that
     * the `mask-image` approach used with all of the other images doesn't work
     * here; hence why we still have two versions of this particular image. */
		--loading-icon: url(images/loading-dark.svg);
	}
}

@media screen and (forced-colors: active) {
	:root {
		--button-hover-color: Highlight;
		--doorhanger-hover-bg-color: Highlight;
		--toolbar-icon-opacity: 1;
		--toolbar-icon-bg-color: ButtonText;
		--toolbar-icon-hover-bg-color: ButtonFace;
		--toggled-hover-active-btn-color: ButtonText;
		--toggled-hover-btn-outline: 2px solid ButtonBorder;
		--toolbar-border-color: CanvasText;
		--toolbar-border-bottom: 1px solid var(--toolbar-border-color);
		--toolbar-box-shadow: none;
		--toggled-btn-color: HighlightText;
		--toggled-btn-bg-color: LinkText;
		--doorhanger-hover-color: ButtonFace;
		--doorhanger-border-color-whcm: 1px solid ButtonText;
		--doorhanger-triangle-opacity-whcm: 0;
		--dialog-button-border: 1px solid Highlight;
		--dialog-button-hover-bg-color: Highlight;
		--dialog-button-hover-color: ButtonFace;
		--dropdown-btn-border: 1px solid ButtonText;
		--field-border-color: ButtonText;
		--main-color: CanvasText;
		--separator-color: GrayText;
		--doorhanger-separator-color: GrayText;
		--toolbarSidebar-box-shadow: none;
		--toolbarSidebar-border-bottom: 1px solid var(--toolbar-border-color);
	}
}

@media screen and (prefers-reduced-motion: reduce) {
	:root {
		--sidebar-transition-duration: 0;
	}
}

* {
	padding: 0;
	margin: 0;
}

html,
body {
	height: 100%;
	width: 100%;
}

body {
	background-color: var(--body-bg-color);
	scrollbar-color: var(--scrollbar-color) var(--scrollbar-bg-color);
}

.hidden,
[hidden] {
	display: none !important;
}

#viewerContainer.pdfPresentationMode:-webkit-full-screen {
	top: 0;
	background-color: rgba(0, 0, 0, 1);
	width: 100%;
	height: 100%;
	overflow: hidden;
	cursor: none;
	-webkit-user-select: none;
	user-select: none;
}

#viewerContainer.pdfPresentationMode:fullscreen {
	top: 0;
	background-color: rgba(0, 0, 0, 1);
	width: 100%;
	height: 100%;
	overflow: hidden;
	cursor: none;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
}

.pdfPresentationMode:-webkit-full-screen section:not([data-internal-link]) {
	pointer-events: none;
}

.pdfPresentationMode:fullscreen section:not([data-internal-link]) {
	pointer-events: none;
}

.pdfPresentationMode:-webkit-full-screen .textLayer span {
	cursor: none;
}

.pdfPresentationMode:fullscreen .textLayer span {
	cursor: none;
}

.pdfPresentationMode.pdfPresentationModeControls > *,
.pdfPresentationMode.pdfPresentationModeControls .textLayer span {
	cursor: default;
}

#outerContainer {
	width: 100%;
	height: 100%;
	position: relative;
}

#sidebarContainer {
	position: absolute;
	inset-block: 32px 0;
	inset-inline-start: calc(-1 * var(--sidebar-width));
	width: var(--sidebar-width);
	visibility: hidden;
	z-index: 100;
	font: message-box;
	border-top: 1px solid rgba(51, 51, 51, 1);
	border-inline-end: var(--doorhanger-border-color-whcm);
	transition-property: inset-inline-start;
	transition-duration: var(--sidebar-transition-duration);
	transition-timing-function: var(--sidebar-transition-timing-function);
}

#outerContainer:is(.sidebarMoving, .sidebarOpen) #sidebarContainer {
	visibility: visible;
}

#outerContainer.sidebarOpen #sidebarContainer {
	inset-inline-start: 0;
}

#mainContainer {
	position: absolute;
	inset: 0;
	min-width: 350px;
}

#sidebarContent {
	inset-block: 32px 0;
	inset-inline-start: 0;
	overflow: auto;
	position: absolute;
	width: 100%;
	box-shadow: inset calc(-1px * var(--dir-factor)) 0 0 rgba(0, 0, 0, 0.25);
}

#viewerContainer {
	overflow: auto;
	position: absolute;
	inset: 32px 0 0;
	outline: none;
}

#viewerContainer:not(.pdfPresentationMode) {
	transition-duration: var(--sidebar-transition-duration);
	transition-timing-function: var(--sidebar-transition-timing-function);
}

#outerContainer.sidebarOpen #viewerContainer:not(.pdfPresentationMode) {
	inset-inline-start: var(--sidebar-width);
	transition-property: inset-inline-start;
}

.toolbar {
	position: relative;
	inset-inline: 0;
	z-index: 9999;
	cursor: default;
	font: message-box;
}

:is(.toolbar, .editorParamsToolbar, .findbar, #sidebarContainer) :is(input, button, select),
.secondaryToolbar :is(input, button, a, select) {
	outline: none;
	font: message-box;
}

#toolbarContainer {
	width: 100%;
}

#toolbarSidebar {
	width: 100%;
	height: 32px;
	background-color: var(--sidebar-toolbar-bg-color);
	box-shadow: var(--toolbarSidebar-box-shadow);
	border-bottom: var(--toolbarSidebar-border-bottom);
}

#sidebarResizer {
	position: absolute;
	inset-block: 0;
	inset-inline-end: -6px;
	width: 6px;
	z-index: 200;
	cursor: ew-resize;
}

#toolbarContainer,
.findbar,
.secondaryToolbar,
.editorParamsToolbar {
	position: relative;
	height: 32px;
	background-color: var(--toolbar-bg-color);
	box-shadow: var(--toolbar-box-shadow);
	border-bottom: var(--toolbar-border-bottom);
}

#toolbarViewer {
	height: 32px;
}

#loadingBar {
	/* Define these variables here, and not in :root, to avoid reflowing the
     entire viewer when updating progress (see issue 15958). */
	--progressBar-percent: 0%;
	--progressBar-end-offset: 0;

	position: absolute;
	inset-inline: 0 var(--progressBar-end-offset);
	height: 4px;
	background-color: var(--progressBar-bg-color);
	border-bottom: 1px solid var(--toolbar-border-color);
	transition-property: inset-inline-start;
	transition-duration: var(--sidebar-transition-duration);
	transition-timing-function: var(--sidebar-transition-timing-function);
}

#outerContainer.sidebarOpen #loadingBar {
	inset-inline-start: var(--sidebar-width);
}

#loadingBar .progress {
	position: absolute;
	top: 0;
	inset-inline-start: 0;
	width: 100%;
	transform: scaleX(var(--progressBar-percent));
	transform-origin: calc(50% - 50% * var(--dir-factor)) 0;
	height: 100%;
	background-color: var(--progressBar-color);
	overflow: hidden;
	transition: transform 200ms;
}

@keyframes progressIndeterminate {
	0% {
		transform: translateX(calc(-142px * var(--dir-factor)));
	}

	100% {
		transform: translateX(0);
	}
}

#loadingBar.indeterminate .progress {
	transform: none;
	background-color: var(--progressBar-bg-color);
	transition: none;
}

#loadingBar.indeterminate .progress .glimmer {
	position: absolute;
	top: 0;
	inset-inline-start: 0;
	height: 100%;
	width: calc(100% + 150px);
	background: repeating-linear-gradient(135deg,
			var(--progressBar-blend-color) 0,
			var(--progressBar-bg-color) 5px,
			var(--progressBar-bg-color) 45px,
			var(--progressBar-color) 55px,
			var(--progressBar-color) 95px,
			var(--progressBar-blend-color) 100px);
	animation: progressIndeterminate 1s linear infinite;
}

#outerContainer.sidebarResizing :is(#sidebarContainer, #viewerContainer, #loadingBar) {
	/* Improve responsiveness and avoid visual glitches when the sidebar is resized. */
	transition-duration: 0s;
}

.findbar,
.secondaryToolbar,
.editorParamsToolbar {
	top: 32px;
	position: absolute;
	z-index: 30000;
	height: auto;
	padding: 0 4px;
	margin: 4px 2px;
	font: message-box;
	font-size: 12px;
	line-height: 14px;
	text-align: left;
	cursor: default;
}

.findbar {
	inset-inline-start: 64px;
	min-width: 300px;
	background-color: var(--toolbar-bg-color);
}

.findbar > div {
	height: 32px;
}

.findbar > div#findbarInputContainer {
	margin-inline-end: 4px;
}

.findbar.wrapContainers > div,
.findbar.wrapContainers > div#findbarMessageContainer > * {
	clear: both;
}

.findbar.wrapContainers > div#findbarMessageContainer {
	height: auto;
}

.findbar input[type="checkbox"] {
	pointer-events: none;
}

.findbar label {
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
}

.findbar label:hover,
.findbar input:focus-visible + label {
	color: var(--toggled-btn-color);
	background-color: var(--button-hover-color);
}

.findbar .toolbarField[type="checkbox"]:checked + .toolbarLabel {
	background-color: var(--toggled-btn-bg-color) !important;
	color: var(--toggled-btn-color);
}

#findInput {
	width: 200px;
}

#findInput::-moz-placeholder {
	font-style: normal;
}

#findInput::placeholder {
	font-style: normal;
}

#findInput[data-status="pending"] {
	background-image: var(--loading-icon);
	background-repeat: no-repeat;
	background-position: calc(50% + 48% * var(--dir-factor));
}

#findInput[data-status="notFound"] {
	background-color: rgba(255, 102, 102, 1);
}

.secondaryToolbar,
.editorParamsToolbar {
	padding: 6px 0 10px;
	inset-inline-end: 4px;
	height: auto;
	background-color: var(--doorhanger-bg-color);
}

.editorParamsToolbarContainer {
	width: 220px;
	margin-bottom: -4px;
}

.editorParamsToolbarContainer > .editorParamsSetter {
	min-height: 26px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-inline: 10px;
}

.editorParamsToolbarContainer .editorParamsLabel {
	padding-inline-end: 10px;
	flex: none;
	color: var(--main-color);
}

.editorParamsToolbarContainer .editorParamsColor {
	width: 32px;
	height: 32px;
	flex: none;
}

.editorParamsToolbarContainer .editorParamsSlider {
	background-color: transparent;
	width: 90px;
	flex: 0 1 0;
}

.editorParamsToolbarContainer .editorParamsSlider::-moz-range-progress {
	background-color: black;
}

.editorParamsToolbarContainer .editorParamsSlider::-webkit-slider-runnable-track,
.editorParamsToolbarContainer .editorParamsSlider::-moz-range-track {
	background-color: black;
}

.editorParamsToolbarContainer .editorParamsSlider::-webkit-slider-thumb,
.editorParamsToolbarContainer .editorParamsSlider::-moz-range-thumb {
	background-color: white;
}

#secondaryToolbarButtonContainer {
	max-width: 220px;
	min-height: 26px;
	max-height: calc(var(--viewer-container-height) - 40px);
	overflow-y: auto;
	margin-bottom: -4px;
}

#editorStampParamsToolbar {
	inset-inline-end: 40px;
	background-color: var(--toolbar-bg-color);
}

#editorInkParamsToolbar {
	inset-inline-end: 68px;
	background-color: var(--toolbar-bg-color);
}

#editorFreeTextParamsToolbar {
	inset-inline-end: 96px;
	background-color: var(--toolbar-bg-color);
}

#editorStampAddImage::before {
	-webkit-mask-image: var(--editorParams-stampAddImage-icon);
	mask-image: var(--editorParams-stampAddImage-icon);
}

.doorHanger,
.doorHangerRight {
	border-radius: 2px;
	box-shadow:
		0 1px 5px var(--doorhanger-border-color),
		0 0 0 1px var(--doorhanger-border-color);
	border: var(--doorhanger-border-color-whcm);
}

:is(.doorHanger, .doorHangerRight)::after,
:is(.doorHanger, .doorHangerRight)::before {
	bottom: 100%;
	border: 8px solid rgba(0, 0, 0, 0);
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	opacity: var(--doorhanger-triangle-opacity-whcm);
}

.doorHanger::after {
	inset-inline-start: 10px;
	margin-inline-start: -8px;
	border-bottom-color: var(--toolbar-bg-color);
}

.doorHangerRight::after {
	inset-inline-end: 10px;
	margin-inline-end: -8px;
	border-bottom-color: var(--doorhanger-bg-color);
}

:is(.doorHanger, .doorHangerRight)::before {
	border-bottom-color: var(--doorhanger-border-color);
	border-width: 9px;
}

.doorHanger::before {
	inset-inline-start: 10px;
	margin-inline-start: -9px;
}

.doorHangerRight::before {
	inset-inline-end: 10px;
	margin-inline-end: -9px;
}

#findResultsCount {
	background-color: rgba(217, 217, 217, 1);
	color: rgba(82, 82, 82, 1);
	text-align: center;
	padding: 4px 5px;
	margin: 5px;
}

#findMsg[data-status="notFound"] {
	font-weight: bold;
}

:is(#findResultsCount, #findMsg):empty {
	display: none;
}

#toolbarViewerMiddle {
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
}

#toolbarViewerLeft,
#toolbarSidebarLeft {
	float: var(--inline-start);
}

#toolbarViewerRight,
#toolbarSidebarRight {
	float: var(--inline-end);
}

#toolbarViewerLeft > *,
#toolbarViewerMiddle > *,
#toolbarViewerRight > *,
#toolbarSidebarLeft *,
#toolbarSidebarRight *,
.findbar * {
	position: relative;
	float: var(--inline-start);
}

#toolbarViewerLeft {
	padding-inline-start: 1px;
}

#toolbarViewerRight {
	padding-inline-end: 1px;
}

#toolbarSidebarRight {
	padding-inline-end: 2px;
}

.splitToolbarButton {
	margin: 2px;
	display: inline-block;
}

.splitToolbarButton > .toolbarButton {
	float: var(--inline-start);
}

.toolbarButton,
.secondaryToolbarButton,
.dialogButton {
	border: none;
	background: none;
	width: 28px;
	height: 28px;
	outline: none;
}

.dialogButton:is(:hover, :focus-visible) {
	background-color: var(--dialog-button-hover-bg-color);
}

.dialogButton:is(:hover, :focus-visible) > span {
	color: var(--dialog-button-hover-color);
}

.toolbarButton > span {
	display: inline-block;
	width: 0;
	height: 0;
	overflow: hidden;
}

:is(.toolbarButton, .secondaryToolbarButton, .dialogButton)[disabled] {
	opacity: 0.5;
}

.splitToolbarButton > .toolbarButton:is(:hover, :focus-visible),
.dropdownToolbarButton:hover {
	background-color: var(--button-hover-color);
}

.splitToolbarButton > .toolbarButton {
	position: relative;
	margin: 0;
}

#toolbarSidebar .splitToolbarButton > .toolbarButton {
	margin-inline-end: 2px;
}

.splitToolbarButtonSeparator {
	float: var(--inline-start);
	margin: 4px 0;
	width: 1px;
	height: 20px;
	background-color: var(--separator-color);
}

.toolbarButton,
.dropdownToolbarButton,
.secondaryToolbarButton,
.dialogButton {
	min-width: 16px;
	margin: 2px 1px;
	padding: 2px 6px 0;
	border: none;
	border-radius: 2px;
	color: var(--main-color);
	font-size: 12px;
	line-height: 14px;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	cursor: default;
	box-sizing: border-box;
}

.toolbarButton:is(:hover, :focus-visible) {
	background-color: var(--button-hover-color);
}

.secondaryToolbarButton:is(:hover, :focus-visible) {
	background-color: var(--doorhanger-hover-bg-color);
	color: var(--doorhanger-hover-color);
}

:is(.toolbarButton, .secondaryToolbarButton).toggled,
.splitToolbarButton.toggled > .toolbarButton.toggled {
	background-color: var(--toggled-btn-bg-color);
	color: var(--toggled-btn-color);
}

:is(.toolbarButton, .secondaryToolbarButton).toggled:hover,
.splitToolbarButton.toggled > .toolbarButton.toggled:hover {
	outline: var(--toggled-hover-btn-outline) !important;
}

:is(.toolbarButton, .secondaryToolbarButton).toggled::before {
	background-color: var(--toggled-btn-color);
}

:is(.toolbarButton, .secondaryToolbarButton).toggled:hover:active,
.splitToolbarButton.toggled > .toolbarButton.toggled:hover:active {
	background-color: var(--toggled-hover-active-btn-color);
}

.dropdownToolbarButton {
	/* Define this variable here, and not in :root, to avoid reflowing the
     entire viewer when updating the width. */
	--scale-select-width: 140px;

	width: var(--scale-select-width);
	padding: 0;
	background-color: var(--dropdown-btn-bg-color);
	border: var(--dropdown-btn-border);
}

.dropdownToolbarButton::after {
	top: 6px;
	inset-inline-end: 6px;
	pointer-events: none;
	-webkit-mask-image: var(--toolbarButton-menuArrow-icon);
	mask-image: var(--toolbarButton-menuArrow-icon);
}

.dropdownToolbarButton > select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: inherit;
	height: 28px;
	font-size: 14px !important;
	color: var(--main-color);
	margin: 0;
	padding: 1px 0 2px;
	padding-inline-start: 6px;
	border: none;
	background-color: var(--dropdown-btn-bg-color);
}

.dropdownToolbarButton > select:is(:hover, :focus-visible) {
	background-color: var(--button-hover-color);
	color: var(--toggled-btn-color);
}

.dropdownToolbarButton > select > option {
	background: var(--doorhanger-bg-color);
	color: var(--main-color);
}

.toolbarButtonSpacer {
	width: 30px;
	display: inline-block;
	height: 1px;
}

:is(.toolbarButton, .secondaryToolbarButton, .treeItemToggler)::before,
.dropdownToolbarButton::after {
	/* All matching images have a size of 16x16
   * All relevant containers have a size of 28x28 */
	position: absolute;
	display: inline-block;
	width: 16px;
	height: 16px;

	content: "";
	background-color: var(--toolbar-icon-bg-color);
	-webkit-mask-size: cover;
	mask-size: cover;
}

.dropdownToolbarButton:is(:hover, :focus-visible, :active)::after {
	background-color: var(--toolbar-icon-hover-bg-color);
}

.toolbarButton::before {
	opacity: var(--toolbar-icon-opacity);
	top: 6px;
	left: 6px;
}

.toolbarButton:is(:hover, :focus-visible)::before,
.secondaryToolbarButton:is(:hover, :focus-visible)::before {
	background-color: var(--toolbar-icon-hover-bg-color);
}

.secondaryToolbarButton::before {
	opacity: var(--doorhanger-icon-opacity);
	top: 5px;
	inset-inline-start: 12px;
}

#sidebarToggle::before {
	-webkit-mask-image: var(--toolbarButton-sidebarToggle-icon);
	mask-image: var(--toolbarButton-sidebarToggle-icon);
	transform: scaleX(var(--dir-factor));
}

#secondaryToolbarToggle::before {
	-webkit-mask-image: var(--toolbarButton-secondaryToolbarToggle-icon);
	mask-image: var(--toolbarButton-secondaryToolbarToggle-icon);
	transform: scaleX(var(--dir-factor));
}

#findPrevious::before {
	-webkit-mask-image: var(--findbarButton-previous-icon);
	mask-image: var(--findbarButton-previous-icon);
}

#findNext::before {
	-webkit-mask-image: var(--findbarButton-next-icon);
	mask-image: var(--findbarButton-next-icon);
}

#previous::before {
	-webkit-mask-image: var(--toolbarButton-pageUp-icon);
	mask-image: var(--toolbarButton-pageUp-icon);
}

#next::before {
	-webkit-mask-image: var(--toolbarButton-pageDown-icon);
	mask-image: var(--toolbarButton-pageDown-icon);
}

#zoomOut::before {
	-webkit-mask-image: var(--toolbarButton-zoomOut-icon);
	mask-image: var(--toolbarButton-zoomOut-icon);
}

#zoomIn::before {
	-webkit-mask-image: var(--toolbarButton-zoomIn-icon);
	mask-image: var(--toolbarButton-zoomIn-icon);
}

#presentationMode::before {
	-webkit-mask-image: var(--toolbarButton-presentationMode-icon);
	mask-image: var(--toolbarButton-presentationMode-icon);
}

#editorFreeText::before {
	-webkit-mask-image: var(--toolbarButton-editorFreeText-icon);
	mask-image: var(--toolbarButton-editorFreeText-icon);
}

#editorInk::before {
	-webkit-mask-image: var(--toolbarButton-editorInk-icon);
	mask-image: var(--toolbarButton-editorInk-icon);
}

#editorStamp::before {
	-webkit-mask-image: var(--toolbarButton-editorStamp-icon);
	mask-image: var(--toolbarButton-editorStamp-icon);
}

#print::before,
#secondaryPrint::before {
	-webkit-mask-image: var(--toolbarButton-print-icon);
	mask-image: var(--toolbarButton-print-icon);
}

:is(#openFile, #secondaryOpenFile)::before {
	-webkit-mask-image: var(--toolbarButton-openFile-icon);
	mask-image: var(--toolbarButton-openFile-icon);
}

:is(#download, #secondaryDownload)::before {
	-webkit-mask-image: var(--toolbarButton-download-icon);
	mask-image: var(--toolbarButton-download-icon);
}

a.secondaryToolbarButton {
	padding-top: 5px;
	text-decoration: none;
}

a:is(.toolbarButton, .secondaryToolbarButton)[href="#"] {
	opacity: 0.5;
	pointer-events: none;
}

#viewBookmark::before {
	-webkit-mask-image: var(--toolbarButton-bookmark-icon);
	mask-image: var(--toolbarButton-bookmark-icon);
}

#viewThumbnail::before {
	-webkit-mask-image: var(--toolbarButton-viewThumbnail-icon);
	mask-image: var(--toolbarButton-viewThumbnail-icon);
}

#viewOutline::before {
	-webkit-mask-image: var(--toolbarButton-viewOutline-icon);
	mask-image: var(--toolbarButton-viewOutline-icon);
	transform: scaleX(var(--dir-factor));
}

#viewAttachments::before {
	-webkit-mask-image: var(--toolbarButton-viewAttachments-icon);
	mask-image: var(--toolbarButton-viewAttachments-icon);
}

#viewLayers::before {
	-webkit-mask-image: var(--toolbarButton-viewLayers-icon);
	mask-image: var(--toolbarButton-viewLayers-icon);
}

#currentOutlineItem::before {
	-webkit-mask-image: var(--toolbarButton-currentOutlineItem-icon);
	mask-image: var(--toolbarButton-currentOutlineItem-icon);
	transform: scaleX(var(--dir-factor));
}

#viewFind::before {
	-webkit-mask-image: var(--toolbarButton-search-icon);
	mask-image: var(--toolbarButton-search-icon);
}

.pdfSidebarNotification::after {
	position: absolute;
	display: inline-block;
	top: 2px;
	inset-inline-end: 2px;
	/* Create a filled circle, with a diameter of 9 pixels, using only CSS: */
	content: "";
	background-color: rgba(112, 219, 85, 1);
	height: 9px;
	width: 9px;
	border-radius: 50%;
}

.secondaryToolbarButton {
	position: relative;
	margin: 0;
	padding: 0 0 1px;
	padding-inline-start: 36px;
	height: auto;
	min-height: 26px;
	width: auto;
	min-width: 100%;
	text-align: start;
	white-space: normal;
	border-radius: 0;
	box-sizing: border-box;
	display: inline-block;
}

.secondaryToolbarButton > span {
	padding-inline-end: 4px;
}

#firstPage::before {
	-webkit-mask-image: var(--secondaryToolbarButton-firstPage-icon);
	mask-image: var(--secondaryToolbarButton-firstPage-icon);
}

#lastPage::before {
	-webkit-mask-image: var(--secondaryToolbarButton-lastPage-icon);
	mask-image: var(--secondaryToolbarButton-lastPage-icon);
}

#pageRotateCcw::before {
	-webkit-mask-image: var(--secondaryToolbarButton-rotateCcw-icon);
	mask-image: var(--secondaryToolbarButton-rotateCcw-icon);
}

#pageRotateCw::before {
	-webkit-mask-image: var(--secondaryToolbarButton-rotateCw-icon);
	mask-image: var(--secondaryToolbarButton-rotateCw-icon);
}

#cursorSelectTool::before {
	-webkit-mask-image: var(--secondaryToolbarButton-selectTool-icon);
	mask-image: var(--secondaryToolbarButton-selectTool-icon);
}

#cursorHandTool::before {
	-webkit-mask-image: var(--secondaryToolbarButton-handTool-icon);
	mask-image: var(--secondaryToolbarButton-handTool-icon);
}

#scrollPage::before {
	-webkit-mask-image: var(--secondaryToolbarButton-scrollPage-icon);
	mask-image: var(--secondaryToolbarButton-scrollPage-icon);
}

#scrollVertical::before {
	-webkit-mask-image: var(--secondaryToolbarButton-scrollVertical-icon);
	mask-image: var(--secondaryToolbarButton-scrollVertical-icon);
}

#scrollHorizontal::before {
	-webkit-mask-image: var(--secondaryToolbarButton-scrollHorizontal-icon);
	mask-image: var(--secondaryToolbarButton-scrollHorizontal-icon);
}

#scrollWrapped::before {
	-webkit-mask-image: var(--secondaryToolbarButton-scrollWrapped-icon);
	mask-image: var(--secondaryToolbarButton-scrollWrapped-icon);
}

#spreadNone::before {
	-webkit-mask-image: var(--secondaryToolbarButton-spreadNone-icon);
	mask-image: var(--secondaryToolbarButton-spreadNone-icon);
}

#spreadOdd::before {
	-webkit-mask-image: var(--secondaryToolbarButton-spreadOdd-icon);
	mask-image: var(--secondaryToolbarButton-spreadOdd-icon);
}

#spreadEven::before {
	-webkit-mask-image: var(--secondaryToolbarButton-spreadEven-icon);
	mask-image: var(--secondaryToolbarButton-spreadEven-icon);
}

#documentProperties::before {
	-webkit-mask-image: var(--secondaryToolbarButton-documentProperties-icon);
	mask-image: var(--secondaryToolbarButton-documentProperties-icon);
}

.verticalToolbarSeparator {
	display: block;
	margin: 5px 2px;
	width: 1px;
	height: 22px;
	background-color: var(--separator-color);
}

.horizontalToolbarSeparator {
	display: block;
	margin: 6px 0;
	height: 1px;
	width: 100%;
	background-color: var(--doorhanger-separator-color);
}

.toolbarField {
	padding: 4px 7px;
	margin: 3px 0;
	border-radius: 2px;
	background-color: var(--field-bg-color);
	background-clip: padding-box;
	border: 1px solid var(--field-border-color);
	box-shadow: none;
	color: var(--field-color);
	font-size: 14px !important;
	line-height: 16px;
	outline: none;
}

.toolbarField[type="checkbox"] {
	opacity: 0;
	position: absolute !important;
	left: 0;
	margin: 10px 0 3px;
	margin-inline-start: 7px;
}

#pageNumber {
	-moz-appearance: textfield;
	/* hides the spinner in moz */
	text-align: end;
	width: 40px;
	background-size: 0 0;
	transition-property: none;
}

#pageNumber.visiblePageIsLoading {
	background-image: var(--loading-icon);
	background-repeat: no-repeat;
	background-position: calc(50% - 42% * var(--dir-factor));
	background-size: 16px 16px;
	/* Using a delay with background-image doesn't work,
     consequently we use background-size. */
	transition-property: background-size;
	transition-delay: var(--loading-icon-delay);
}

#pageNumber::-webkit-inner-spin-button {
	-webkit-appearance: none;
}

.toolbarField:focus {
	border-color: #0a84ff;
}

.toolbarLabel {
	min-width: 16px;
	padding: 7px;
	margin: 2px;
	border-radius: 2px;
	color: var(--main-color);
	font-size: 12px;
	line-height: 14px;
	text-align: left;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	cursor: default;
}

#numPages.toolbarLabel {
	padding-inline-start: 3px;
}

#thumbnailView,
#outlineView,
#attachmentsView,
#layersView {
	position: absolute;
	width: calc(100% - 8px);
	inset-block: 0;
	padding: 4px 4px 0;
	overflow: auto;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
}

#thumbnailView {
	width: calc(100% - 60px);
	padding: 10px 30px 0;
}

#thumbnailView > a:is(:active, :focus) {
	outline: 0;
}

.thumbnail {
	/* Define these variables here, and not in :root, since the individual
     thumbnails may have different sizes. */
	--thumbnail-width: 0;
	--thumbnail-height: 0;

	float: var(--inline-start);
	width: var(--thumbnail-width);
	height: var(--thumbnail-height);
	margin: 0 10px 5px;
	padding: 1px;
	border: 7px solid transparent;
	border-radius: 2px;
}

#thumbnailView > a:last-of-type > .thumbnail {
	margin-bottom: 10px;
}

a:focus > .thumbnail,
.thumbnail:hover {
	border-color: var(--thumbnail-hover-color);
}

.thumbnail.selected {
	border-color: var(--thumbnail-selected-color) !important;
}

.thumbnailImage {
	width: var(--thumbnail-width);
	height: var(--thumbnail-height);
	opacity: 0.9;
}

a:focus > .thumbnail > .thumbnailImage,
.thumbnail:hover > .thumbnailImage {
	opacity: 0.95;
}

.thumbnail.selected > .thumbnailImage {
	opacity: 1 !important;
}

.thumbnail:not([data-loaded]) > .thumbnailImage {
	width: calc(var(--thumbnail-width) - 2px);
	height: calc(var(--thumbnail-height) - 2px);
	border: 1px dashed rgba(132, 132, 132, 1);
}

.treeWithDeepNesting > .treeItem,
.treeItem > .treeItems {
	margin-inline-start: 20px;
}

.treeItem > a {
	text-decoration: none;
	display: inline-block;
	/* Subtract the right padding (left, in RTL mode) of the container: */
	min-width: calc(100% - 4px);
	height: auto;
	margin-bottom: 1px;
	padding: 2px 0 5px;
	padding-inline-start: 4px;
	border-radius: 2px;
	color: var(--treeitem-color);
	font-size: 13px;
	line-height: 15px;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	white-space: normal;
	cursor: pointer;
}

#layersView .treeItem > a * {
	cursor: pointer;
}

#layersView .treeItem > a > label {
	padding-inline-start: 4px;
}

#layersView .treeItem > a > label > input {
	float: var(--inline-start);
	margin-top: 1px;
}

.treeItemToggler {
	position: relative;
	float: var(--inline-start);
	height: 0;
	width: 0;
	color: rgba(255, 255, 255, 0.5);
}

.treeItemToggler::before {
	inset-inline-end: 4px;
	-webkit-mask-image: var(--treeitem-expanded-icon);
	mask-image: var(--treeitem-expanded-icon);
}

.treeItemToggler.treeItemsHidden::before {
	-webkit-mask-image: var(--treeitem-collapsed-icon);
	mask-image: var(--treeitem-collapsed-icon);
	transform: scaleX(var(--dir-factor));
}

.treeItemToggler.treeItemsHidden ~ .treeItems {
	display: none;
}

.treeItem.selected > a {
	background-color: var(--treeitem-selected-bg-color);
	color: var(--treeitem-selected-color);
}

.treeItemToggler:hover,
.treeItemToggler:hover + a,
.treeItemToggler:hover ~ .treeItems,
.treeItem > a:hover {
	background-color: var(--treeitem-bg-color);
	background-clip: padding-box;
	border-radius: 2px;
	color: var(--treeitem-hover-color);
}

.dialogButton {
	width: auto;
	margin: 3px 4px 2px !important;
	padding: 2px 11px;
	color: var(--main-color);
	background-color: var(--dialog-button-bg-color);
	border: var(--dialog-button-border) !important;
}

dialog {
	margin: auto;
	padding: 15px;
	border-spacing: 4px;
	color: var(--main-color);
	font: message-box;
	font-size: 12px;
	line-height: 14px;
	background-color: var(--doorhanger-bg-color);
	border: 1px solid rgba(0, 0, 0, 0.5);
	border-radius: 4px;
	box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
}

dialog::backdrop {
	background-color: rgba(0, 0, 0, 0.2);
}

dialog > .row {
	display: table-row;
}

dialog > .row > * {
	display: table-cell;
}

dialog .toolbarField {
	margin: 5px 0;
}

dialog .separator {
	display: block;
	margin: 4px 0;
	height: 1px;
	width: 100%;
	background-color: var(--separator-color);
}

dialog .buttonRow {
	text-align: center;
	vertical-align: middle;
}

dialog :link {
	color: rgba(255, 255, 255, 1);
}

#passwordDialog {
	text-align: center;
}

#passwordDialog .toolbarField {
	width: 200px;
}

#documentPropertiesDialog {
	text-align: left;
}

#documentPropertiesDialog .row > * {
	min-width: 100px;
	text-align: start;
}

#documentPropertiesDialog .row > span {
	width: 125px;
	word-wrap: break-word;
}

#documentPropertiesDialog .row > p {
	max-width: 225px;
	word-wrap: break-word;
}

#documentPropertiesDialog .buttonRow {
	margin-top: 10px;
}

.grab-to-pan-grab {
	cursor: grab !important;
}

.grab-to-pan-grab *:not(input):not(textarea):not(button):not(select):not(:link) {
	cursor: inherit !important;
}

.grab-to-pan-grab:active,
.grab-to-pan-grabbing {
	cursor: grabbing !important;
}

.grab-to-pan-grabbing {
	position: fixed;
	background: rgba(0, 0, 0, 0);
	display: block;
	inset: 0;
	overflow: hidden;
	z-index: 50000;
	/* should be higher than anything else in PDF.js! */
}

@page {
	margin: 0;
}

#printContainer {
	display: none;
}

@media print {
	body {
		background: rgba(0, 0, 0, 0) none;
	}

	body[data-pdfjsprinting] #outerContainer {
		display: none;
	}

	body[data-pdfjsprinting] #printContainer {
		display: block;
	}

	#printContainer {
		height: 100%;
	}

	/* wrapper around (scaled) print canvas elements */
	#printContainer > .printedPage {
		page-break-after: always;
		page-break-inside: avoid;

		/* The wrapper always cover the whole page. */
		height: 100%;
		width: 100%;

		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
	}

	#printContainer > .xfaPrintedPage .xfaPage {
		position: absolute;
	}

	#printContainer > .xfaPrintedPage {
		page-break-after: always;
		page-break-inside: avoid;
		width: 100%;
		height: 100%;
		position: relative;
	}

	#printContainer > .printedPage :is(canvas, img) {
		/* The intrinsic canvas / image size will make sure that we fit the page. */
		max-width: 100%;
		max-height: 100%;

		direction: ltr;
		display: block;
	}
}

.visibleLargeView,
.hiddenLargeView,
.hiddenMediumView,
.verticalToolbarSeparator,
.visibleMediumView {
	display: none;
}

@media all and (max-width: 900px) {
	#toolbarViewerMiddle {
		display: table;
		margin: auto;
		left: auto;
		position: inherit;
		transform: none;
	}
}

@media all and (max-width: 840px) {
	#sidebarContainer {
		background-color: var(--sidebar-narrow-bg-color);
	}

	#outerContainer.sidebarOpen #viewerContainer {
		inset-inline-start: 0 !important;
	}
}

@media all and (max-width: 820px) {
	#outerContainer .hiddenLargeView {
		display: none;
	}

	#outerContainer .visibleLargeView {
		display: inherit;
	}
}

@media all and (max-width: 750px) {
	#outerContainer .hiddenMediumView {
		display: none;
	}

	#outerContainer .visibleMediumView {
		display: inherit;
	}
}

@media all and (max-width: 690px) {

	.hiddenSmallView,
	.hiddenSmallView * {
		display: none;
	}

	.toolbarButtonSpacer {
		width: 0;
	}

	.findbar {
		inset-inline-start: 34px;
	}
}

@media all and (max-width: 560px) {
	#scaleSelectContainer {
		display: none;
	}
}